package com.dsl.dslsuzhou.model.dto;

import lombok.Data;

/**
 * 统一API响应格式
 */
@Data
public class ApiResponse<T> {
    
    /**
     * 响应码（0表示成功）
     */
    private Integer code;
    
    /**
     * 响应消息
     */
    private String message;
    
    /**
     * 响应数据
     */
    private T data;
    
    public ApiResponse() {}
    
    public ApiResponse(Integer code, String message, T data) {
        this.code = code;
        this.message = message;
        this.data = data;
    }
    
    /**
     * 成功响应
     */
    public static <T> ApiResponse<T> success(T data) {
        return new ApiResponse<>(0, "成功", data);
    }
    
    /**
     * 成功响应（带自定义消息）
     */
    public static <T> ApiResponse<T> success(String message, T data) {
        return new ApiResponse<>(0, message, data);
    }
    
    /**
     * 错误响应
     */
    public static <T> ApiResponse<T> error(Integer code, String message) {
        return new ApiResponse<>(code, message, null);
    }
    
    /**
     * 参数错误
     */
    public static <T> ApiResponse<T> badRequest(String message) {
        return new ApiResponse<>(400, "参数错误：" + message, null);
    }
    
    /**
     * 未授权
     */
    public static <T> ApiResponse<T> unauthorized() {
        return new ApiResponse<>(401, "未授权", null);
    }
    
    /**
     * 第三方服务错误
     */
    public static <T> ApiResponse<T> thirdPartyError() {
        return new ApiResponse<>(502, "第三方服务错误", null);
    }
    
    /**
     * 服务超时
     */
    public static <T> ApiResponse<T> timeout() {
        return new ApiResponse<>(504, "服务超时", null);
    }
}
